<script setup lang="ts">
/**
 * 引入
 */
import { onMounted, ref } from 'vue'
import { phoneRule, passwordRule, codeRule } from '@/utils/rules'
import { login, sendMobileCode, loginByMobile } from '@/services'
import { showSuccessToast, showToast, type FormInstance } from 'vant'
import { useUserStore } from '@/stores'
import { useRouter, useRoute } from 'vue-router'

// 密码
const mobile = ref('')
const password = ref('')
const agree = ref(false)
const show = ref(false)

const toRegister = () => {
  console.log('跳转到注册页')
}

/**
 * 发送短信验证码
 */
const code = ref('')
const time = ref(0)
const isPass = ref(true)
// 定义van-form表单类型
const form = ref<FormInstance | null>(null)
const send = async () => {
  // 校验是否正在倒计时
  if (time.value > 0) return
  // 验证手机号格式
  await form.value?.validate('mobile')
  // 发送请求
  await sendMobileCode(mobile.value, 'login')
  // 发送成功提示
  showSuccessToast('短信发送成功')
  // 倒计时
  time.value = 60
  let timerId = setInterval(() => {
    time.value--
    if (time.value === 0) clearInterval(timerId)
  }, 1000)
}

/**
 * 登录功能
 */
const userStore = useUserStore()
const router = useRouter()
const route = useRoute()
const tologin = async () => {
  // 1. 点击同意
  if (!agree.value) return showToast('点击我已同意用户协议')
  // 2. 发送请求
  // 7. 我们根据 isPass 来判断是否是短信登录
  const res = isPass.value
    ? await login(mobile.value, password.value)
    : await loginByMobile(mobile.value, code.value)
  // 3. 将数据赋值给全局数据
  userStore.user = res.data
  // 5. 提示用户登录成功
  showSuccessToast('登录成功')
  /**
   * 6. 登录成功之后跳转
   *    1. 如果之前有返回的地址   直接跳转到返回的地址
   *    2. 如果之前没有返回的地址  跳转到用户页面
   *    3. 登录跳转不需要历史地址
   *    4. 如果有返回的地址就返回到这个地址,如果没有就返回到这个登录页面
   *    5. router.push 他的跳转是有路由记录的
   *    6. router.replace 他的跳转时没有路由记录的
   */
  router.replace((route.query.returnUrl as string) || '/user')
}

// redirect_uri  这里代表的是回调地址
// 环境变量不能够在魔板字符串中使用, 所以我们在js中声明然后绑定在模板中使用
// %2 代表的是  /
const qqUrl = `https://graph.qq.com/oauth2.0/authorize?client_id=102015968&response_type=token&scope=all&redirect_uri=${encodeURIComponent(
  import.meta.env.VITE_APP_CALLBACK + '/login/callback'
)}`
</script>

<template>
  <div class="login-page">
    <!-- 导航 -->
    <cp-nav-bar right-text="注册" @click-right="toRegister"></cp-nav-bar>
    <!-- 头部 -->
    <!-- 文字切换 结构切换 -->
    <div class="login-head">
      <h3>{{ isPass ? '密码登录' : '短信验证码登录' }}</h3>
      <a href="javascript:;" @click="isPass = !isPass">
        <span>{{ isPass ? '短信验证码登录' : '密码登录' }}</span>
        <van-icon name="arrow"></van-icon>
      </a>
    </div>
    <!-- form 表单 -->
    <!-- form 表单 -->
    <van-form autocomplete="off" @submit="tologin" ref="form">
      <!-- 手机号 -->
      <van-field
        name="mobile"
        v-model="mobile"
        placeholder="请输入手机号"
        type="text"
        :rules="phoneRule"
      ></van-field>
      <!-- 密码 -->
      <!-- 点击图标切换密码显示和隐藏 并且切换图标的状态 -->
      <van-field
        v-if="isPass"
        v-model="password"
        placeholder="请输入密码"
        :type="show ? 'text' : 'password'"
        :rules="passwordRule"
      >
        <template #button>
          <CpIcon
            @click="show = !show"
            :name="`login-eye-${show ? 'on' : 'off'}`"
            color="#16c2a3"
          ></CpIcon>
        </template>
      </van-field>

      <!-- 短信验证码 -->
      <van-field v-else v-model="code" placeholder="请输入短信验证码" :rules="codeRule">
        <template #button>
          <span class="btn-send" @click="send" :class="{ active: time > 0 }">
            {{ time > 0 ? `${time}s后再次发送` : '发送验证码' }}
          </span>
        </template>
      </van-field>

      <div class="cp-cell">
        <van-checkbox v-model="agree">
          <span>我已同意</span>
          <a href="javascript:;">用户协议</a>
          <span>及</span>
          <a href="javascript:;">隐私条款</a>
        </van-checkbox>
      </div>
      <div class="cp-cell">
        <van-button block round type="primary" native-type="submit">登 录</van-button>
      </div>
      <div class="cp-cell">
        <a href="javascript:;">忘记密码？</a>
      </div>
    </van-form>
    <!-- 底部 -->
    <div class="login-other">
      <van-divider>第三方登录</van-divider>
      <a class="icon" :href="qqUrl">
        <img src="@/assets/qq.svg" alt="" />
      </a>
    </div>
  </div>
</template>

<style lang="scss" scoped>
.login {
  &-page {
    padding-top: 46px;
  }
  &-head {
    padding: 30px 30px 50px;
    display: flex;
    justify-content: space-between;
    align-items: flex-end;
    line-height: 1;
    h3 {
      font-weight: normal;
      font-size: 24px;
    }
    a {
      font-size: 15px;
    }
  }
  &-other {
    margin-top: 60px;
    padding: 0 30px;
    .icon {
      display: flex;
      justify-content: center;
      img {
        width: 36px;
        height: 36px;
        padding: 4px;
      }
    }
  }
}

.van-form {
  padding: 0 14px;
  .cp-cell {
    height: 52px;
    line-height: 24px;
    padding: 14px 16px;
    box-sizing: border-box;
    display: flex;
    align-items: center;
    .van-checkbox {
      a {
        color: var(--cp-primary);
        padding: 0 5px;
      }
    }
  }
}

.btn-send {
  color: var(--cp-primary);
  &.active {
    color: rgba(22, 194, 163, 0.5);
  }
}
</style>
